Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[ENH] Add and Validate n_layers, n_units, activation & dropout_rate kwargs to MLPNetwork #2338

Open
wants to merge 13 commits into
base: main
Choose a base branch
from

Conversation

aadya940
Copy link
Contributor

Closes #2337 .

@aeon-actions-bot aeon-actions-bot bot added enhancement New feature, improvement request or other non-bug code enhancement networks Networks package labels Nov 11, 2024
@aeon-actions-bot
Copy link
Contributor

Thank you for contributing to aeon

I have added the following labels to this PR based on the title: [ $\color{#FEF1BE}{\textsf{enhancement}}$ ].
I have added the following labels to this PR based on the changes made: [ $\color{#379E11}{\textsf{networks}}$ ]. Feel free to change these if they do not properly represent the PR.

The Checks tab will show the status of our automated tests. You can click on individual test runs in the tab or "Details" in the panel below to see more information if there is a failure.

If our pre-commit code quality check fails, any trivial fixes will automatically be pushed to your PR unless it is a draft.

Don't hesitate to ask questions on the aeon Slack channel if you have any.

PR CI actions

These checkboxes will add labels to enable/disable CI functionality for this PR. This may not take effect immediately, and a new commit may be required to run the new configuration.

  • Run pre-commit checks for all files
  • Run mypy typecheck tests
  • Run all pytest tests and configurations
  • Run all notebook example tests
  • Run numba-disabled codecov tests
  • Stop automatic pre-commit fixes (always disabled for drafts)
  • Disable numba cache loading
  • Push an empty commit to re-run CI checks

@aadya940 aadya940 added the deep learning Deep learning related label Nov 11, 2024
Copy link
Member

@hadifawaz1999 hadifawaz1999 left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thx for taking care of it.
In general:

  • All parameters should be defined as private in constructor before starting anything
  • the assertions and all the list checking should only be in build_network method not constructor, this will avoid causing issues on CI (check for example how fcn network is implemented)
  • Also given we are parametrizing the network, the associated classifier and regressor should be parametrized as such (also docs) and use them when calling the network
  • I left some other comments to check

aeon/networks/_mlp.py Outdated Show resolved Hide resolved
aeon/networks/_mlp.py Show resolved Hide resolved
aeon/networks/_mlp.py Outdated Show resolved Hide resolved
aeon/networks/_mlp.py Outdated Show resolved Hide resolved
aeon/networks/_mlp.py Outdated Show resolved Hide resolved
aeon/networks/_mlp.py Show resolved Hide resolved
aeon/networks/_mlp.py Outdated Show resolved Hide resolved
aeon/networks/_mlp.py Outdated Show resolved Hide resolved
Copy link
Member

@hadifawaz1999 hadifawaz1999 left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Looks great, just the original default number of units is actually 500 not 200, once this is changed we can get this in

dschrempf added a commit to dschrempf/aeon that referenced this pull request Jan 21, 2025
Comment on lines +31 to +32
Dropout rate(s) for each dense layer. If None, a default rate of 0.2 is used.
Dropout rate(s) are typically a number in the interval [0, 1].
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

As far as I can see, if dropout_rate is None, it will be set to

            self._dropout_rate = [0.1]
            self._dropout_rate.extend([0.2] * (self.n_layers - 1))

I think we should adapt this info.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
deep learning Deep learning related enhancement New feature, improvement request or other non-bug code enhancement networks Networks package
Projects
None yet
Development

Successfully merging this pull request may close these issues.

[ENH] Parametrize MLP Network, classifier and regressor
4 participants